package com.ys.controller.api.report;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.ys.config.MenuId;
import com.ys.entity.report.ReFinanceExamine;
import com.ys.entity.report.TcoBusinessDataGs;
import com.ys.entity.report.TcoBusinessDataStat;
import com.ys.entity.sys.YsCol;
import com.ys.service.report.TcoBusinessDataGsService;
import com.ys.service.report.TcoBusinessDataStatService;
import com.ys.service.sys.CommonApiService;
import com.ys.service.sys.UploadService.UploadDto;
import com.ys.util.ExportExcelUtils;
import com.ys.vo.LayuiTableVoJA;
import com.ys.vo.R;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.List;
import java.util.Map;

@Controller
@RequestMapping("/api/inter/tcoBusinessDataGs")
public class ApiInterTcoBusinessDataGsController {
    private static final Logger logger = LoggerFactory.getLogger(ApiInterTcoBusinessDataGsController.class);
    private static Long MENU_ID = MenuId.TCO_BusinessDataGs;

    @Autowired
    private CommonApiService<TcoBusinessDataGs> commonApiService;

    @Autowired
    private TcoBusinessDataGsService tcoBusinessDataGsService;
    /**
     * 设置查询的cond的sql设置
     * @param cond
     * @return
     */
    public TcoBusinessDataGs setSeachSql(TcoBusinessDataGs cond){

        cond.addLeftJoin("THR_OperateCompanyApply B ON B.Vgsbm = A.Vgsbm")
                .addField("B.Vgsjc AS vgsjcStr");
        //排序
        cond.setOrderby("A.Vgsbm ASC");
        return  cond;
    }


    /**
     * 查询
     */
    @RequiresPermissions("tcoBusinessDataGs:view")
    @RequestMapping("/search")
    @ResponseBody
    public LayuiTableVoJA search(Model model, HttpServletRequest request, HttpServletResponse response,
                                 @ModelAttribute TcoBusinessDataGs cond
    ){
        try {
            cond = setSeachSql(cond);
            LayuiTableVoJA tableVoJA = commonApiService.searchLay(cond);
            return tableVoJA;
        }catch (Exception e){
            logger.error("查询出错：",e.getMessage(),e);
            LayuiTableVoJA tableVoJA = new LayuiTableVoJA();
            tableVoJA.setCode(1);
            tableVoJA.setMsg("查询出错，请稍后重试！");
            return tableVoJA;
        }
    }


    /**
     * 导出
     */
    @RequestMapping("/export")
    @ResponseBody
    public R export(@ModelAttribute TcoBusinessDataGs cond){
        try {
            cond.setPage(0).setSize(999999);
            cond = setSeachSql(cond);
            //获取菜单字段数据
            List<YsCol> listField = new YsCol()
                    .setMenuId(MENU_ID)
                    .where("A.Code != 'ope'")
                    .setOrderby("A.SortNo asc")
                    .queryList();
            //获取数据
            List<Map<String, Object>> listData = cond.queryMap();
            //处理数据
            ExportExcelUtils<ReFinanceExamine> util = new ExportExcelUtils<>(new ReFinanceExamine());
            String toFilePath = util.exportExcel(listData, listField, "数据统计店铺清单");
            UploadDto dto = commonApiService.uploadLocalToServer(toFilePath);
            return R.ok(dto.getUrl());
        }catch (Exception e){
            logger.error("导出出错：",e.getMessage(),e);
            return R.error("导出失败，请稍后重试！");
        }
    }




    /**
     * 新增
     */
    @RequestMapping("/add")
    @ResponseBody
    public R add(HttpServletRequest request, @RequestParam Map<String, Object> params){
        try {
            if(params.get("vgsbm")==null || "".equals(params.get("vgsbm").toString())){
                return R.error("未选择公司");
            }
            return tcoBusinessDataGsService.add(params.get("vgsbm").toString());
        } catch (Exception e) {
            logger.error("出错：",e.getMessage(),e);
            return R.error(e.getCause().getMessage());
        }
    }


    /**
     * 新增
     */
    @RequestMapping("/del")
    @ResponseBody
    public R del(HttpServletRequest request, @RequestParam Map<String, Object> params){
        try {
            String choooseDatas = params.get("choooseDatas").toString();
            //获取数据
            JSONArray detailList = JSON.parseArray(choooseDatas);
            return tcoBusinessDataGsService.del(detailList);
        } catch (Exception e) {
            logger.error("出错：",e.getMessage(),e);
            return R.error(e.getCause().getMessage());
        }
    }



}